

IIC2343 - Arquitectura de Computadores (II/2018)

### VHSIC Hardware Description Language

Breve Tutorial de VHDL para Vivado

# 1. Descripción

VHDL es un lenguaje que nos permite simular el comportamiento de circuitos. A diferencia de un lenguaje tradicional de programación, que se ejecuta secuencialmente, lo que es descrito en el lenguaje se emula en circuito concurrente. Originalmente fue desarrollado por el departamento de defensa de los Estados Unidos para simular circuitos, pero hoy también se utiliza para programar FPGAs como la Basys3.

### 2. Crear Componentes

Para iniciarlos en el proyecto partiremos creando un Half Adder. Primero deben agregar un nuevo diseño desde "Proyect Manager - Add Source" y elegiremos "Add or create design sources". Desde esa opción crearemos un nuevo archivo de tipo VHDL y nombre "HA", se pueden agregar o importar mas de un archivo de ser necesario. Una vez finalizado nos permitirá' elegir el nombre y las características de los puertos de entrada y salida de los componentes que crearon, en este caso "a" y "b" como entradas, y "s" y "c" como salidas.

```
library IEEE; — includes
   use IEEE.STD_LOGIC_1164.ALL;
3
4
   entity HA is -- declaracion de la entidad
      Port (a: in std_logic; — definition de puertos
6
 7
             b : in std_logic ;
8
             s : out std_logic;
9
             c : out std_logic);
  end HA;
10
11
  architecture Behavioral of HA is
12
13
           -- declaraciones y definiciones
14
  begin
15
           -- conecciones e instancias
  end Behavioral;
```

Código generado con una breve descripción de las partes.

Como vieron en clases el comportamiento de un HA debe simular la suma dos bits "a" y "b", dando como resultado una suma "s" y un carry "c". Esto implica que "s" será 1 solo si "a" o "b" es 1, y "c" será 1 solo si "a" y "b" son 1. Las compuertas lógicas para esas operaciones son Xor y And respectivamente. Para expresar eso el código es el siguiente:

```
architecture Behavioral of HA is

begin

s <= a xor b;
c <= a and b;

end Behavioral;
```

## 3. Usar Componentes

Para anidar componentes primero deben ser ser declarados, luego instanciados y conectados. a continuación un ejemplo de como declarar e instanciar dos HA.

```
12 architecture Behavioral of FA is
13
   component HA -- Declaracion del HA
14
       Port (a : in std_logic;
15
16
              b : in std_logic;
              s : out std_logic;
17
18
              c : out std_logic);
19
       end component;
20
   signal s1 : std_logic ; -- Declaracion de senales
   signal c1 : std_logic;
   signal c2 : std_logic ;
23
24
25
   begin
26
27
   c \ll c1 and c2;
28
29
   inst_HA: HA port map( -- Primera instancia de HA
                  =>'1', -- Conexiones de los puertos de la instancia
30
31
           b
                  =>'0',
32
           \mathbf{S}
                  =>s1,
33
                  =>c1
           \mathbf{c}
34
       );
35
36 inst_HA2: HA port map( -- Segunda instancia de HA
37
                  =>'0',
           a
           b
                  =>'1',
38
                  =>'0',
39
           \mathbf{S}
40
           \mathbf{c}
                  =>c2
41
       );
42
43 end Behavioral;
```

No usar como referencia, la lógica de las conexiones es incorrecta.

## 4. Bonus: Muxers

El código a continuación representa 4 muxers, impleméntelos en su proyecto para probarlos.

```
42 begin
43
44 with sw select
      dis_a \le "0111" when "110",
45
      "0000" when others;
46
47
48 with sw select
      dis_b \le "0111" when "110",
49
      "0000" when others;
50
51
52 with sw select
      dis_c <= "0001" when "110",
53
54
      "0000" when others;
55
56 with sw select
      dis_{-}d <= "1000" when "110",
57
      "0000" when others;
```